﻿--- Eliminar las funciones existentes sin importar el numero ni tipo de parametros
SELECT * FROM "DropFunction_AWIL"('FuncSeguridadParametroTipo');
--- crear una nueva funcion
CREATE FUNCTION "FuncSeguridadParametroTipo"(
	 IN	"@OP" CHARACTER VARYING(64)
	,IN	"@paramAux" TEXT
	,INOUT	"@id" INTEGER
	,INOUT	"@fechaGrab" timestamp
	,INOUT	"@usuarioGrab" character varying(32)
	,INOUT	"@activo" boolean
	,INOUT	"@codParametroTipo" character varying(32)
	,INOUT	"@nombreParametroTipo" character varying(128)
	,INOUT	"@descripcion" character varying(256)
	,INOUT	"@orden" INTEGER
)RETURNS 
	SETOF RECORD
AS $$ 
DECLARE
	Auxiliar TEXT;
BEGIN

	/*SELECT BY CODIGO*/
	IF "@OP"='selectByCodigo' THEN
		RETURN	QUERY
		SELECT	"id","fechaGrab","usuarioGrab","activo","codParametroTipo","nombreParametroTipo","descripcion","orden"
		FROM	"SeguridadParametroTipo"
		WHERE	"codParametroTipo"="@codParametroTipo";
	RETURN;
	END IF;

	/*SELECT TODOS*/
	IF "@OP"='selectAll' THEN
		RETURN	QUERY
		SELECT	"id","fechaGrab","usuarioGrab","activo","codParametroTipo","nombreParametroTipo","descripcion","orden"
		FROM	"SeguridadParametroTipo";
	RETURN;
	END IF;

	/*INSERTAR NUEVO REGISTRO*/
	IF "@OP"='insert' THEN

		--- Verifico que no exista  con ese CODIGO
		IF EXISTS (SELECT 1 FROM "SeguridadParametroTipo" WHERE "codParametroTipo"="@codParametroTipo") THEN
			Auxiliar = 'Ya existe un Tipo de parametro con el codigo "' || "@codParametroTipo" || '", verifique.';
			RAISE EXCEPTION '%', Auxiliar;
		END IF;

		--- Verifico que no exista con ese NOMBRE
		IF EXISTS (SELECT 1 FROM "SeguridadParametroTipo" WHERE "nombreParametroTipo"="@nombreParametroTipo") THEN
			Auxiliar = 'Ya existe un Tipo de parametro con el Nombre "' || "@nombreParametroTipo" || '", verifique.';
			RAISE EXCEPTION '%', Auxiliar;
		END IF;

		-- Grabo el registro
		INSERT INTO "SeguridadParametroTipo" ("usuarioGrab","usuarioUltMod","activo","codParametroTipo","nombreParametroTipo","descripcion","orden")
		VALUES	 ("@usuarioGrab","@usuarioGrab",coalesce("@activo",TRUE),"@codParametroTipo","@nombreParametroTipo","@descripcion",coalesce("@orden",0));

		RETURN	QUERY SELECT "id","fechaGrab","usuarioGrab","activo","codParametroTipo","nombreParametroTipo","descripcion","orden" FROM "SeguridadParametroTipo" ORDER BY "id" DESC LIMIT 1;
	RETURN;
	END IF;

	/*ACTUALIZAR REGISTRO*/
	IF "@OP"='update' THEN
		--- Verifico que no exista  con el nuevo CODIGO
		IF EXISTS (SELECT 1 FROM "SeguridadParametroTipo" WHERE "codParametroTipo"="@codParametroTipo" AND "id"<>"@id") THEN
			Auxiliar = 'Ya existe Otro Tipo de parametro con el codigo "' || "@codParametroTipo" || '", verifique.';
			RAISE EXCEPTION '%', Auxiliar;
		END IF;

		--- Verifico que no exista  con ese NOMBRE
		IF EXISTS (SELECT 1 FROM "SeguridadParametroTipo" WHERE "nombreParametroTipo"="@nombreParametroTipo" AND "id"<>"@id") THEN
			Auxiliar = 'Ya existe Otro Tipo de parametro con el Nombre "' || "@nombreParametroTipo" || '", verifique.';
			RAISE EXCEPTION '%', Auxiliar;
		END IF;

		--- Actualizo el registro
		UPDATE	
			"SeguridadParametroTipo" 
		SET	
			 "activo"=coalesce("@activo","activo")
			,"fechaUltMod"=NOW() 
			,"usuarioUltMod"="@usuarioGrab" 
			,"codParametroTipo"="@codParametroTipo"
			,"nombreParametroTipo"="@nombreParametroTipo"			
			,"descripcion"="@descripcion"
			,"orden"="@orden"
		WHERE	
			"id"="@id";

	RETURN;
	END IF;

	/*ELIMINAR REGISTRO*/
	IF "@OP"='delete' THEN

		--- Borro el registro
		DELETE FROM "SeguridadParametroTipo" 
		WHERE "id"="@id";

	RETURN;
	END IF;


--- Controlo que se haya digitado el OP correctamente
	IF "@OP" IS NOT NULL THEN
		Auxiliar = 'El OP "' || "@OP" || '" No existe, verifique.';
		RAISE EXCEPTION '%', Auxiliar;
	RETURN;
	END IF;
END;
$$ LANGUAGE 'plpgsql';

